1 CLAIMS

2

What is claimed is:

4

1

2

3

4

5

6 **[**]7

刊0 同1 []1

占3 四4

<u>ā</u>6

H17

18

19

20

21

22

23

24

25

26

27

28

29

- 1. A data-flow and context-flow data processing system comprising a plurality of data driven cores capable of switching between a plurality of contexts, wherein the plurality of data driven cores comprises a plurality of distributed multi-context storage units each capable of storing a plurality of context parameters corresponding to the plurality of contexts, each multi-context storage unit comprising:
  - a) a context register bank comprising
    - plurality of context parameter registers for storing the plurality of context parameters, each context parameter register storing of the contexts, parameter for one plurality of context parameter registers having a corresponding plurality of inputs connected input connection, and a corresponding to an plurality of outputs; and
    - a multiplexer having a plurality of multiplexer inputs each connected to a corresponding one of the plurality of context parameter register outputs, for selecting a current context parameter set for transmission to a multiplexer output;
  - b) a context identification register connected to the context register bank, for storing a current context identification token identifying a current context for the context register bank, wherein
    - the context identification register is connected to a select line of the multiplexer, for controlling the multiplexer to select the

₫3

☐ 

current context parameter set for transmission; and

- the context identification register is connected to a load enable line of each of the context parameter registers, for enabling an updating of a current context parameter set in a corresponding context parameter register; and
- c) logic connected to the multiplexer output for receiving the current context parameter set and processing a set of data tokens according to the current context parameter set, connected to the input connection of the context parameter registers for providing updated context parameter sets to the context parameter registers, and connected to the context identification register for propagating the current context identification token through the multi-context storage unit.
- 2. The system of claim 1, further comprising logic for controlling a flow of the set of data tokens through the cores such that each data token is transferred from a first core to a second core upon a synchronous assertion of a request signal from the second core to the first core, and of a ready signal from the first core to the second core.
- 3. The system of claim 1, wherein an interface of a core includes a content specification flag for indicating whether a token containing the flag is a data token or a context identification token.
- 4. The system of claim 1, wherein an interface of a core includes a dedicated context identification field for

| transferrin | ng a | a curr | rent | con | text  | id | enti | fication  | token |
|-------------|------|--------|------|-----|-------|----|------|-----------|-------|
| with each d | lata | token  | pass | ing | throu | gh | the  | interface |       |

5

1

2

3

4

5

7

8

₫0

日<sub>6</sub>日7

19

3 4

> \( \) 5. A data-flow and context-flow data processing system, comprising a plurality of data-driven cores including:

> > a) logic for controlling a flow of data tokens and context identification tokens through the cores;

- b) a plurality of distributed multi-context storage units, each multi-context storage unit including:
  - a context identification register for storing a context identification token identifying a current context of said each multi-context storage unit; and
  - a multi-context register bank for storing a plurality of context parameters corresponding to a plurality of contexts,
  - wherein the context identification register is connected to the multi-context register bank for setting the multi-context register bank to the current context; and
- c) logic for processing the data tokens according to a context parameter corresponding to the current context.

21

2

3

4

5

6

7

8

9

10

- A data-flow and context-flow data processing system, comprising a plurality of data-driven cores, each of the cores including:
  - a) a context identification storage unit for storing a current context identification token; and
  - b) logic for controlling a flow of the current context identification token through the cores such that the current context identification token is transferred from a first core to a second core upon a synchronous assertion of a request signal from the

second core to the first core, and of a ready signal from the first core to the second core.

13

11

12

7. A data- and context-flow processing method comprising the steps of:

3 4

5

a) propagating a current context identification token through a plurality of data flow cores integrated on a chip, the current context identification token identifying a current context;

6 7

> 8. 9

Œ٥

b) retrieving a set of context parameters corresponding to the current context from each of a plurality of multi-context storage units distributed through the cores, as the current context identification token propagates through the multi-context storage units; and

27

a)

c) processing a set of data tokens in the current context, according to the set of context parameters.

8. A data- and context-flow data processing system comprising a first data- and context-flow core and a second data- and context-flow core integrated on a chip, the first core comprising:

6 7 8

9

10

11

context identification token from the second core, the context identification token identifying one of a plurality of contexts as a current context, wherein each token transfer between the second core and the first core occurs upon a synchronous assertion of a request signal from the first core to the second core and a ready signal from the second

an input interface for receiving a data token and a

12 13

14

15

16

b) a context identification register connected to the input interface, for storing the context identification token;

core to the first core;

| 17         | c) a multi-context storage unit connected to the          |
|------------|-----------------------------------------------------------|
| 18         | context identification register, for storing a            |
| 19         | plurality of context parameters corresponding to the      |
| 20         | plurality of contexts;                                    |
| 21         | d) control and processing logic connected to the          |
| 22         | context identification register and the context           |
| 23         | register bank, for                                        |
| 24 \       |                                                           |
| 1 9.       | A data- and context-flow data processing system           |
| 2          | comprising a plurality of cores, each of the cores        |
| 3          | comprising:                                               |
| <b>4</b>   | a) an input control bus for transferring input control    |
|            | signals;                                                  |
| 1          | b) an input token bus for receiving input tokens in       |
| i 7        | response to assertions of the input control signals,      |
| <b>D</b> 8 | the input tokens including                                |
| л<br>Л     | an input data token to be processed by the core, and      |
| : 10       | an input context identification token for specifying      |
| 11<br>12   | a current context;                                        |
| 12         | c) an output control bus for transferring output          |
| = 1<br>1   | control signals; and                                      |
| 14         | d) an output token bus for sending output tokens in       |
| 15         | response to assertions of the output control              |
| 16         | signals, the output tokens including                      |
| 17         | an output data token derived from the input data          |
| 18         | token, and                                                |
| 19         | an output context identification token equal to the       |
| 20         | input context identification token, for                   |
| 21         | specifying the current context.                           |
| 22         |                                                           |
| 1 10.      | A multithreaded data processing system comprising a first |
| 2          | data-driven core, a second data-driven core, and a third  |
| 3          | data-driven core integrated on a chip, the first core     |

comprising:

| ,                                      | ω, | a first input interface connected to the second      |
|----------------------------------------|----|------------------------------------------------------|
| 6                                      |    | core, comprising                                     |
| 7                                      |    | a first input request connection for asserting a     |
| 8                                      |    | first input request signal to the second core,       |
| 9                                      |    | a first input ready connection for receiving a first |
| 10                                     |    | input ready signal asserted by the second core,      |
| 11                                     |    | and                                                  |
| 12                                     |    | a first input data connection for receiving from the |
| 13                                     |    | second core an input context token for               |
| 14                                     |    | establishing a context state for the first           |
| 15                                     |    | core;                                                |
| ₫6                                     | b) | processing logic connected to the first input        |
|                                        |    | interface, for processing a data token according to  |
| <b>₩</b> 8                             |    | the context state;                                   |
| <b>-1</b> 9                            | c) | a first output interface connected to the third      |
| 7<br>8<br>9<br>9<br>0<br>1             |    | core, comprising                                     |
| 1                                      |    | a first output request connection for receiving a    |
| # 22<br>CD 3<br>CD 4<br>CD 5<br>CD 126 |    | first output request signal asserted by the          |
| <b>□</b> 3                             |    | third core,                                          |
| ₫4                                     |    | a first output ready connection for asserting a      |
| ₩25                                    |    | first output ready signal to the third core,         |
| <u>2</u> 6                             |    | and                                                  |
| 27                                     |    | a first output data connection connected to the      |
| 28                                     |    | processing logic, for transmitting to the third      |
| 29                                     |    | core a first output context token derived from       |
| 30                                     |    | the first input token, for establishing the          |
| 31                                     |    | context state for the third core;                    |
| 32                                     | d) | first input control logic connected to the first     |
| 33                                     |    | input interface, for controlling the first core to   |
| 34                                     |    | receive the first input context token if the first   |
| 35                                     |    | input request signal and the first input ready       |
| 36                                     |    | signal are asserted with a predetermined synchronous |
| 37                                     |    | relationship: and                                    |

e) first output control logic connected to the first output interface, for controlling the first core to transmit the first output context token to the third core if the first output request signal and the first output ready signal are asserted with a predetermined synchronous relationship.

44 1

2

3

**4** 5

ழ ஹ்7

N N 9

110

₩ 11

**1**2

□ 2□ 3

5

6 7

9

10

38

39

40

41

42

43

- 11. The system of claim 10 wherein:
  - a) the first input control logic comprises logic for controlling the first core to receive the first input context token if the first input request signal and the first input ready signal are asserted synchronously; and
  - b) the first output control logic comprises logic for controlling the first core to transmit the first output context token to the third core if the first output request signal and the first output ready signal are asserted synchronously.

12. The system of claim 11 wherein:

- a) the first input control logic comprises logic for controlling the first core to receive the first input context token synchronously with the first input request signal and the input ready signal; and
- b) the first output control logic comprises logic for controlling the first core to transmit the first output context token synchronously with the first output request signal and the output ready signal.

11 12 1

13. The system of claim 10 wherein:

| :   | 2                |  |
|-----|------------------|--|
|     | 3                |  |
|     | 4                |  |
|     | 5                |  |
|     | 6                |  |
|     | 7                |  |
|     | 8                |  |
|     | 9                |  |
| 1   | 0                |  |
| 1   | 1                |  |
| 1   | 2                |  |
| 1   | 3                |  |
| 2   | 5<br>6<br>7<br>8 |  |
| 3   | 2                |  |
| يجه | 3                |  |
|     | 4                |  |
|     | 5                |  |
|     | 1                |  |
|     | 2                |  |
|     | 3                |  |

4

5

7

8

- a) the first core further comprises a second output interface connected to a fourth core integrated on the chip, the second output interface comprising
  - a second output request connection for receiving a second output request signal asserted by the fourth core,
  - a second output ready connection for asserting a second output ready signal to the fourth core, and
  - a second output data connection connected to the data processing logic, for transmitting the output context token to the fourth core; and
- b) the first core further comprises second output control logic connected to the second output interface, for controlling the first core to transmit the output context token to the fourth core if the second output request signal and the second output ready signal are asserted synchronously.
- 14. The system of claim 10, wherein the first core further comprises a multi-context storage unit connected to the processing logic, for storing a plurality of context parameters corresponding to a plurality of contexts.
  - 15. The system of claim 14 wherein the multi-context storage unit comprises:
    - a) a plurality of registers connected in parallel, for storing a plurality of context parameter values for a corresponding plurality of contexts; and
    - b) a multiplexer connected to the outputs of the plurality of registers, for selecting for transmission a value of the context parameter

08/08/01 QUA-103

| 10                                                                 |                   | corresponding to a current context state for              |
|--------------------------------------------------------------------|-------------------|-----------------------------------------------------------|
| 11                                                                 |                   | the multi-context storage unit.                           |
| 12                                                                 | •                 |                                                           |
| 1                                                                  | \ <sub>16</sub> . | A multithreaded data processing system comprising a first |
| 2                                                                  |                   | data-driven core and a second data-driven core, the first |
| 3                                                                  |                   | core comprising an input interface connected to the       |
| 4                                                                  |                   | second core, the input interface including:               |
| 5                                                                  |                   | a) an input request connection for asserting an input     |
| 6                                                                  |                   | request signal to the second core;                        |
| 7                                                                  |                   | b) an input ready connection for receiving an input       |
| 8                                                                  |                   | ready signal asserted by the second core; and             |
| □9                                                                 |                   | c) an input data connection for receiving from the        |
| 10                                                                 |                   | second core, upon a synchronous assertion of the          |
| <b>1</b> 1                                                         |                   | input request signal and the input ready signal, a        |
| [일<br>14]2                                                         |                   | first input context identification token identifying      |
| 重<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 |                   | a current context state.                                  |
| 世<br>由4                                                            |                   |                                                           |
|                                                                    | 17.               | A multithreaded data processing system comprising a first |
| □<br>m²                                                            |                   | data-driven core, a second data-driven core, and a third  |
| * 1<br>= 1<br>= 2<br>= 3<br>= 4<br>= 5                             |                   | data-driven core integrated on a chip, the first core     |
| <u>Д</u>                                                           |                   | comprising:                                               |
| <u>트</u><br>트 5                                                    |                   | a) an input interface connected to the second core,       |
| 6                                                                  |                   | comprising                                                |
| 7                                                                  |                   | a control bus for transmitting a set of first             |
| 8                                                                  |                   | control signals between the first core and the            |
| 9                                                                  |                   | second core, and                                          |
| 10                                                                 |                   | an input data bus for receiving from the second           |
| 11                                                                 |                   | core, upon the assertion of the set of first              |
| 12                                                                 |                   | control signals according to a predetermined              |
| 13                                                                 |                   | protocol                                                  |
| 14                                                                 |                   | an input data token, and                                  |
| 15                                                                 |                   | an input context identification token for                 |

16

17

the first core;

establishing a current context state in

| 18 | b) | processing logic connected to the first input        |
|----|----|------------------------------------------------------|
| 19 |    | interface, for generating an output data token from  |
| 20 |    | the input data token according to the context state; |
| 21 |    | and                                                  |
| 22 | c) | an output interface connected to the third core,     |
| 23 |    | comprising                                           |
|    |    |                                                      |

- an output control bus for transmitting a set of second control signals between the first core and the third core, and
- an output data bus connected to the processing logic, for transmitting to the third core, upon the assertion of the set of first control signals according to the predetermined protocol the first output token, and
  - a first output context token derived from the first input token, for establishing the current context state in the third core.
- 18. A data- and context-flow data processing method comprising the steps of:
  - a) establishing a first data- and context-driven core and a second data- and context-driven core, the second core being connected to the first core for receiving data tokens and context tokens from the first core; and
  - b) operating the first core in a first context, and concurrently, operating the second core in a second context different from the first context.
- 19. A data- and context-flow processing method comprising the steps of:
  - a) establishing a data- and context-driven core comprising a plurality of interconnected pipestages, the pipestages including

logic for controlling a flow of data tokens and context identification tokens therethrough, and a plurality of distributed multi-context storage units each storing a plurality of context parameters and each responsive to the context identification tokens; and

b) operating a first set of pipestages in a first context specified by a first context identification token present within the first set of pipestages, and concurrently, operating a second set of pipestages in a second context specified by a second context identification token present within the second set of pipestages.